

# BCH (1023, 903, 12) Encoder and Decoder Application notes

Rev. [6/2012] 6-19-2012

# **Table of Contents**

| Introduction                                | . 3 |
|---------------------------------------------|-----|
| Parameters defining BCH encoder and decoder | . 3 |
| General parameters                          | . 3 |
| Code parameters                             | . 3 |
| BCH encoder interface                       | .4  |
| BCH decoder interface                       | . 5 |
| Timing diagram of the encoder               | .6  |
| Decoder's timing diagram                    | . 7 |

### Introduction.

The BCH design includes two independent units, an encoder for generation of the BCH code, and decoder for the BCH code decoding. They can be used separately or together. They are included in separate vhdl files. The encoder is described in the file: "/src/encoder/encoder.vhd". The decoder is described in two files. One of them ("/src/decoder/decoder\_components.vhd") includes essential components, the other ("/src/decoder/decoder.vhd") includes decoder's architecture. The independent parameters, design constants are in the following files: "/src/encoder/encoder\_constants.vhd" for the encoder, and "/src/decoder\_constants.vhd" for the decoder.

Additionally, the design includes the main unit, which tests the correct working of the encoder and decoder units ("/src/main/main.bde"). Testbenches and all scripts needed for simulation and implementation are in the "/src/main/testbench/main\_TB.vhd" file.

The BCH design is available in two versions, in VHDL language (BCH\_1023\_90\_12\_vhdl), and in Verilog language (BCH\_1023\_903\_12\_verilog).

## Parameters defining BCH encoder and decoder.

The Encoder and decoder have parameters, which define it. They are included in separate files (the encoder\_constants.vhd for the encoder, and the decoder\_constant.vhd for the decoder). For verilog version of this design, parameters are not included in separate files, but they are the part of other project files. The most important parameters are as follows:

#### **General parameters**

- **Edge** an active clock edge for the entire project ('1' for rising edge, '0' for falling);
- **Clk\_freq** a clock frequency [MHz], for simulation

(for this project clk\_freq= 50MHz)

#### **Code parameters**

- **m** defines size of GF. For this project m= 10
- n length of codeword in bits. For this project: n= 1023
- **k** number of information bits in a codeword. For this project: k= 903
- t the maximum number of error bits that can be corrected.

For this project: t= 12



## BCH encoder interface.

The encoder and decoder have a similar interface. They differ only by one signal. The encoder has the *data\_in\_en* signal (output signal), while the decoder does not have it.

The encoder's symbol is presented below, in the figure 2.



#### encoder

Figure 2. Encoder symbol.

All encoders' input signals are sampled the on rising clock edge, so they must be valued after it. These signals should be set on falling edge by the previous device.

All encoder's output signals (without *data\_in\_en*) are changed on the falling clock edge, so it allows decoder on sampling it on the rising edge.

The description of encoders' signals is presented below:

- **rst** an input for the reset signal, is active high level. All encoder registers and flops have the synchronous reset, so it is required that this signal lasts minimum for two periods.
- **clk** an input for the clock signal.
- **encode\_en** encodes enable signal, is active high level. When it is high, encoding is enabled, otherwise the entire encoder is disabled. It can last optionally long, and it must be valued before the rising edge.
- **data\_in** an input data for encoding. Data is sent serially on this input, and it must be valued before the rising edge.
- **data\_in\_en** a strobe signal for the input data. It is an output signal, which is changed on the rising clock edge, in order to allow previous device to set its output data on the falling edge. It depends on the *encode\_en* signal, when the *encode\_en* signal is low, the *data\_in\_en* is low too.
- data\_out an output data for the encoder. Data is sent serially by this output to decoder or other device. It is changed on the falling clock edge, so it allows decoder to sample it on the rising edge.
- **data\_out\_en** a strobe signal for the output data. It depends on the *encode\_en* signal, and is low, when the *encode\_en* is low. It is changed on the falling edge too.





#### BCH decoder interface.

The decoder's symbol is presented in the figure 3.



#### decoder

Figure 3. Decoder symbol.

All decoders' input signals are sampled on rising clock edge, so they must be valued after it. These signals are set on the falling edge by the encoder, or other device.

All decoders' output signals are changed on falling clock edge, so it allows other device to sample it on the rising edge.

The signals description is presented below:

- **rst** an input for reset signal, is active high level. All encoder registers and flops have synchronous reset, so it is required that this signal lasts minimum for two periods.
- **clk** an input for the clock signal.
- **encode\_en** encodes the enable signal, is active high level. When it is high, decoding is enabled, otherwise the entire decoder is disabled. It can last optionally long, and it must be valued before the rising edge.
- **data\_in** an input data for decoding. Data is sent serially on this input, and it must be valued before the rising edge.
- **data\_out** an output data for the decoder. Data is sent serially by this output to other devices. It is changed on the falling clock edge so it allows this device to sample it on the rising edge.
- **data\_out\_en** a strobe signal for the output data. It depends on the *encode\_en* signal. It is low, when encode\_en is low. It is changed on the falling edge too.



# Timing diagram of the encoder.

First the encoder's timing diagram shows only 600ns of simulation time. After 60ns of simulation information bits are sent on the encoder's input and they are available on the output after one clock period delay. It is presented in the figure 4.

|             | 1 - 5 | 0 1 | 100     | ı 150     | I         | 200 | I      | 250 | I | 300 | I       | 350 | I | 400     | I | 450 | I | 500     | I      | 550 | I | 600     | ns           |
|-------------|-------|-----|---------|-----------|-----------|-----|--------|-----|---|-----|---------|-----|---|---------|---|-----|---|---------|--------|-----|---|---------|--------------|
| rst         |       |     |         |           |           |     |        |     |   |     |         |     |   |         |   |     |   |         |        |     |   |         |              |
| clk         |       | ΠΠ  | $\prod$ | UU        | Ш         | ЛГ  | $\Box$ |     | Л | ΠΓ  | Г       |     | Л | $\prod$ | Г | Ш   | Л | $\prod$ | $\Box$ | Л   | Л | $\prod$ | $\mathbb{U}$ |
| encode_en   |       |     |         |           |           |     |        |     |   |     |         |     |   |         |   |     |   |         |        |     |   |         |              |
| data_in     |       |     |         |           |           |     |        |     |   |     | 1       | Π   |   |         |   |     |   |         |        |     |   |         |              |
| data_in_en  |       |     |         |           |           |     |        |     |   |     |         |     |   |         |   |     |   |         |        |     |   |         |              |
| data_out    |       |     |         | $\square$ | $\square$ |     |        |     |   |     | <u></u> |     |   |         |   |     |   |         |        |     |   |         |              |
| data_out_en |       |     |         |           |           |     |        |     |   |     |         |     |   |         |   |     |   |         |        |     |   |         |              |

Figure 4. Timing diagram of the encoder.

The next diagram shows a simulation time from 18.10us till 18.50us. From 18.28us the parity bits are generated (after k information bits). It is presented in the figure below (figure 5).

|             | ı • 18,10 • ı • 18,15 • ı 18,20 • ı • 18,25 ı • 18,30 • ı • 18,35 • ı • 18,40 • ı 18,45 • ı US |
|-------------|------------------------------------------------------------------------------------------------|
| rst         |                                                                                                |
| clk         |                                                                                                |
| encode_en   |                                                                                                |
| data_in     |                                                                                                |
| data_in_en  |                                                                                                |
| data_out    |                                                                                                |
| data_out_en |                                                                                                |



Simulation clock frequency for the encoder is equal 50MHz. Reset signal is active by two clock periods. The input data (information for encoding) is sent bit after bit from the *data\_in.txt* file. The output data (encoded information) is recorded in the *data\_out.txt* file. All essential actions are automatically realized by the testbench.



Rev. [6/2012] www.aldec.com

# Decoder's timing diagram.

First the encoder's timing diagram shows only 600ns of simulation time. The input data (encoded) is sent to the decoder's input after an encoding delay (one clock period). It is presented in the figure 6.

|             | т - 50 - т - 100 - т - 150 - т - 200 - т - 250 - т - 300 - т - 350 - т - 400 - т - 450 - т - 500 - т - 550 - т <mark>ns</mark> |
|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| rst         |                                                                                                                                |
| clk         |                                                                                                                                |
| encode_en   |                                                                                                                                |
| data_in     |                                                                                                                                |
| data_out    |                                                                                                                                |
| data_out_en |                                                                                                                                |

Figure 6. Timing diagram of the decoder.

The next diagram shows simulation time from 24.05us till 24.65us. From 24.08us the output data, corrected if needed, is available on the decoder output. It is presented below in the figure 7.

|             | I 24,05 I 24,10 I 24,15 I 24,20 I 24,25 I 24,30 I 24,35 I 24,40 I 24,45 I 24,50 I 24,55 I 24,60 I US |
|-------------|------------------------------------------------------------------------------------------------------|
| rst         |                                                                                                      |
| clk         |                                                                                                      |
| encode_en   |                                                                                                      |
| data_in     |                                                                                                      |
| data_out    |                                                                                                      |
| data_out_en |                                                                                                      |

Figure 7. Timing diagram for decoder.

Simulation clock frequency for the decoder is equal 50MHz. Reset signal is active by two clock periods. The input data (encoded information) is sent bit after bit from the *data\_in.txt* file. The output data (decoded information) is recorded in the *data\_out.txt* file. All essential actions are automatically realized by the testbench.

